草庐IT

c++ - Lua C++ 表迭代

全部标签

c - 迭代 PEB DllName 仅显示 exe 名称

我正在尝试获取我的应用程序中已加载模块的列表(与安全/shellcode有关,因此请避免调用WINAPI)。我正在遍历PEB->Ldr模块双向链表,但每次打印DLL的名称时,它只是打印当前正在执行的应用程序的名称和路径。在其他人的代码中,我看到他们只是将当前的LIST_ENTRY指针设为PLDR_DATA_TABLE_ENTRY,您可以直接调用FullDllName那样。但是,例如,要实际获取基址,您需要调用Reserved2[0]而不是DllBase,这是可以理解的,因为LIST_ENTRY是结构中的8个字节,但它没有解释为什么可以直接调用FullDllName。Here'sanex

c - Windows 10 上的多线程性能比 Linux 差得多

我将一个多线程Linux应用程序移植到Windows,并在运行Windows10专业版的服务器上对其进行测试。与在相同双启动硬件上运行的Linux版本的性能相比,Windows版本的性能非常糟糕。我将代码简化为一个表现出相同症状的小型多线程示例。我希望SO社区能够就此应用程序在Windows和Linux之间存在这种性能差异的原因提供一些见解,并提供有关如何解决该问题的建议。我正在测试的机器具有双IntelXeonGold6136CPU(24/48物理/逻辑内核)@3.0GHz(Turbo加速至3.6GHz)和128GB内存。机器设置为双引导CentOS或Windows10。没有运行Wi

c - 为什么 Windows 要求导入 DLL 数据?

在Windows上,可以从DLL加载数据,但需要通过导入地址表中的指针进行间接访问。因此,编译器必须知道正在访问的对象是否是使用__declspec(dllimport)从DLL导入的。类型说明符。这很不幸,因为这意味着设计用作静态库或动态库的Windows库的header需要知道程序链接到哪个版本的库。此要求不适用于函数,这些函数是为DLL透明地模拟的,stub函数调用实际函数,其地址存储在导入地址表中。在Linux上,动态链接器(ld.so)将所有链接数据对象的值从共享对象复制到每个进程的私有(private)映射区域。这不需要间接寻址,因为私有(private)映射区域的地址是模

windows - 在 Windows Batch 中迭代键值对

我有一个表示设置名称及其值的键值对列表。ssl=strictalways_use_https=onminify={"css":"off","html":"off","js":"off"}key=valuemany=more我想在批处理文件中通过curl请求应用指定设置(键)的每个值:curl-XPATCH"https://api.cloudflare.com/client/v4/zones/%zone%/settings/%key%"^-H"X-Auth-Email:%email%"^-H"X-Auth-Key:%auth%"^-H"Content-Type:application/j

c++ - 正则表达式迭代器在 Cpp 中不起作用

我在VisualStudio2010上使用C++(我不认为它是v11标准,但我还没有检查过)。我正在尝试使用以下代码提取tracert的IP地址:#include#include#include#includeusingnamespacestd;typedefregex_iteratorregexp;#defineMAX_BUFFER255intmain(){stringout;charbuffer[MAX_BUFFER];smatchm;regexe("1.+\\[(.+)\\]");FILE*stream=_popen("tracertSOMEHOSTNAME","r");whil

c++ - 强制 QBENCHMARK 执行多次迭代

如何使用QBENCHMARK执行多次迭代?例如我有这段代码:voidMyUnitTest::speedText(){QBENCHMARK{obj->foo();}}我看了文档,上面写着:ThecodeinsidetheQBENCHMARKmacrowillbemeasured,andpossiblyalsorepeatedseveraltimesinordertogetanaccuratemeasurement.Thisdependsontheselectedmeasurementback-end.我尝试使用默认值和-tickcounter,但两者都只显示一次迭代:默认(无参数):RE

windows - 如果抛出错误,如何跳过循环中的迭代?

我在Windows7cmd中工作。我写了几行代码来从一个相当大的目录树中复制某些文件。这是代码:for/f"tokens=*"%ain('dir"L:\Level1\Level2\Level3\\\*."/ad/b')dorobocopy"L:\Level1\Level2\Level\%a\Level5\Level6\Level7""c:\Destination\%a"/E/V/R:1/W:1/MT:32/SEC基本上,这会进入所有Level4文件夹(在Level3内)并复制在目录其余部分找到的文件。我遇到的问题是我的某些Level4文件夹实际上没有Level5/Level6/Leve

c++ - 如何安全地迭代互锁列表?

我们有存储在互锁单链表中的线程之间共享的数据。https://msdn.microsoft.com/en-us/library/windows/desktop/ms684121(v=vs.85).aspx我们知道列表在初始化后不会改变,但我们希望各个线程能够迭代并读取列表的内容。有没有一种安全的方法来读取/迭代slist?当前代码使用InterlockedFlushSList从列表中取出节点,然后制作数据的临时拷贝,然后将节点放回slist。如果slist在线程之间共享,则似乎是等待发生的竞争条件。如果不使用不同的线程安全结构,是否有一种安全的方法来读取迭代slist?

c - 为什么这个 C 程序在 windows 上崩溃而在 linux 上运行正常?

我写了一个程序来求谐波数(then-thharmonicnumberisthesumofthereciprocalsofthefirstnnaturalnumbers)数字序列。我的程序将其输入作为命令行参数并以表格格式打印谐波数。作为一个例子,它是这样工作的:C:\Users\EDDiE\c>har10305102.9289682539682538153.3182289932289937203.5977396571436819253.8159581777535068303.994987130920390610(argv[1])=startingnumber,30(argv[2])=e

c# - 使用带有 TimeSpan 的 AutoResetEvent.WaitOne 创建迭代低于 1 毫秒的循环

我正在尝试使用以8000个滴答开始的TimeSpan创建一个间隔小于1ms的循环(1个滴答=100ns,因此8000个滴答等于0.8ms或800us):privatestaticvoidMeasureAutoResetEvent(){TimeSpaninterval=newTimeSpan(8000L);//800usdoubleelapsed=0;Stopwatchwatch=newStopwatch();AutoResetEventautoResetEvent=newAutoResetEvent(false);while(true){watch.Restart();autoRese